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(54) Method and device for the management of resources in ATM technique for weighted fair 
queuing (WFQ) applications 

(57) The system (SORTER) includes an input link 
(Bj) on which transit flows of ATM cells belonging to 
service classes with different quality (QoS), and an out- 
put link (B Q ), and including: 

a plurality of transmission queues (QA 1( QA 2 

QA n ); 

a control block (SCB) which contains a respective 
number of access rights to said output link (B 0 ) or 
tokens (TKN,); 

a high priority storage structure (FGB); 
a low priority storage structure (FAB); 
at least one further transmission queue (QNA) 
which contains cells relating to all the flows which 
they transmit at a constant or peak rate, the indica- 
tors of which are contained in said high priority stor- 
age structure. 

The system optionally includes a third storage structure 
with very low priority (FUB) for flows with unspecified 
rate, and a scheduler for the management of flows at 
limited peak rate. 
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Description 

Field of the Invention 

This invention relates in general to a communica- 5 
tion systems which use the numeric technique named 
fast switching of cells or ATM (Asynchronous Transfer 
Mode), for the transport of vocal signals, video signals 
and data. 

More in particular, the invention relates to a method 10 
and device for the management of resources in ATM 
technique for Weighted Fair Queuing (WFQ) applica- 
tions. 

The ATM technique assumes a role of growing 
importance in the integrated switching of flows of is 
numeric signals belonging to services for the transmis- 
sion of vocai and video signals and data, with different 
bandwidth requirements and different traffic character- 
istics. 

The ATM technique provides, in particular, that the 20 
information concerning the various services is organ- 
ized in adjoining units with a fixed length of 424 bits (53 
bytes), named cells. These cells contain, besides the 
real data, a header field which carries, among other 
things, the information necessary for the routing of this 25 
cell across the geographical network. 

The connecting network, which serves to switch 
spatially the cells from an input to an output gate, must 
be capable of disposing of high volumes of traffic, of 
some hundreds of Gbit/s. 30 

The introduction of service priority mechanisms on 
the flow of ATM cells, represented by single connections 
or by groups of connections, is connected with the sup- 
port in the network of more quality classes of the serv- 
ice (QoS). 35 

The need to supply guarantees for sources sensi- 
tive to the delay and, at the same time, the support to 
given applications which, tolerating higher delays, may 
use statistical allocation principles of the bandwidth, 
leads to the need to define and implement suitable inte- 40 
gration schemes in the network. It is also possible to 
introduce service classes with available bandwidth 
(Available Bit Rate, ABR) which make it possible to bet- 
ter use the network resources and therefore offer users 
a more economical service. 45 

Background art 

A well known technique for the implementation of 
the statistical allocation principles of the bandwidth is so 
based on the Weighted Fair Queuing (WFQ) technique. 

The WFQ technique represents a solution to the 
problem of subdividing the service (for example the 
bandwidth available on a link) among a certain number 
of active sessions. The aim is to guarantee that each of 55 
these active sessions receives a certain share propor- 
tional to the prefixed weight r h 

If the sum of the weights r; assigned is lower than 



the bandwidth available on the output link B 0 , each flow 
is guaranteed at least one bandwidth equal to r;. 

The WFQ technique is precisely defined only in the 
case where reference is made to a model of fluid-flow 
type, in which the servant is capable of dividing the 
service into arbitrarily small increases among a number 
of simultaneously active flows. 

An implementable approximation of the WFQ tech- 
nique is represented by the scheduling mechanism 
based on virtual spacing. The virtual spacing mecha- 
nism permits each flow to be served at least with band- 
width rj and to divide any available bandwidth 
(composed of the bandwidth of the link in excess or that 
of the inactive flows) among the active connections in 
proportion to r^ The sessions may be viewed as logical 
queues of waiting cells. The service given to a queue is 
defined "event". 

With the virtual spacing mechanism the scheduling 
of the cells waiting to be served is carried according to 
a priority, whose value is proportional to the weight 
assigned to the queue to which the cell belongs. The 
output link B 0 emits waiting cells in order of priority. 

In the case of virtual spacing, the priority is repre- 
sented by a time stamp, characterizing the virtual time 
of scheduling of the event. The emission of the cells 
takes place according to increasing values of time- 
stamps. 

A key component for the realization of the schedul- 
ing is a device which reorganizes the waiting cells to 
identify those with highest priority. For the implementa- 
tion of this device, sorting algorithms mainly based on 
two mechanisms are known and used, the first on a "vir- 
tual calendar" management, the second on an "intelli- 
gent FIFO" management. 

The "virtual calendar" mechanism reorganizes the 
events on time stamp basis and subsequently scans the 
positions of the calendar. Any events scheduled in the 
same instant are served on FIFO or LIFO basis. Each 
event served is rescheduled in the calendar in a position 
equal to its previous virtual time + time stamp. 

A drawback of the "virtual calendar" mechanism is 
that, to be able to continuously serve the output links, at 
each clock cycle the virtual calendar must be analyzed 
to find the next datum to serve. Since this research is 
not deterministic, possible delays may worsen the effi- 
ciency of the services. Moreover, in practical applica- 
tions, the virtual calendar may easily assume large 
dimensions, which involve the execution of numerous 
research operations at each clock cycle. 

The "intelligent FIFO" mechanism does not reor- 
ganize the events for subsequent time stamps, but, 
through a series of parallel comparisons and shifts, is 
capable, at each request, of supplying the event with the 
smallest time stamp. 

This mechanism solves the research problem but 
involves a rather complex hardware implementation. 
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Objects of the Invention 

The main object of this invention is to supply a 
method for the management of resources in ATM tech- 
nique for Weighted Fair Queuing (WFQ) applications s 
which does not present the drawbacks of the above 
mentioned virtual spacing mechanisms. 

A further object of this invention is to supply a 
method which makes it possible to supply good services 
to real-time applications and to applications which use io 
statistical allocation principles of the bandwidth. 

A particular object of this invention is to supply a 
device which is simple, reliable and inexpensive. 

Summary of the Invention ' is 



peak connections, according to an extended implemen- 
tation of the method and device of the invention, the 
functionality of this machine or WFQ system is 
extended to practically guarantee each type of connec- 
tion, from the top priority connections or the connec- 
tions with constant bit rate (CBR) to the VBR and ABR 
connections and up to the connections of UBR type, or 
connections with unspecified bit rate. A special sched- 
uler solves the problem of guaranteeing, where neces- 
sary, the control of the peak speed in order not to go 
beyond a certain maximum bit rate for these connec- 
tions even if the load conditions of the network would 
permit it The features of the present invention which are 
believed to be novel are set forth with particularity in the 
appended claims. 



These and other objects are reached through the 
invention which is addressed to a method realized in 
compliance with what illustrated in claim 1 . 

Is also object of this invention a device realized in 20 
compliance with what illustrated in claim 9. 

Advantages of the Invention 

Using the method at the base of this invention, even 25 
in the worst case of queues which transmit all at higher 
speed than thiat determined by the minimum bandwidth 
assigned, all the queues are correctly served with at 
least the agreed minimum bandwidth. 

Due to the presence of a flag or test step, the 30 
queues belonging to CBR transmission flows are 
securely served. 

As regards the transmission flows of ABR type, due 
to the presence of a first FIFO, which assumes the role 
of high priority FIFO, the transmission queues present 35 
in it are queues which still have available some of the 
tokens previously assigned to them by the system and 
which are therefore definitely entitled to have their cells 
transmitted on the output link 

Due to the presence of a second FIFO, which 40 
assumes the role of low priority FIFO, the transmission 
queues present in it are queues which have already 
spent all the tokens at their disposal and have surely 
used the minimum bandwidth to be garanteed to them 
to. 45 

Due to the scanning method of the second FIFO, no 
transmission queue manages to monopolize the output 
link, even if it has a large number of cells to transmit. 

In fact, the second FIFO contains queue indicators 
which have completely used up their tokens, regardless so 
of the number of tokens initially assigned to them. 
These queues therefore have an equal right to be 
served. 

While, according to a basic implementation of the 
method and of the device of the invention, are manage- ss 
able by the WFQ machine of the invention connections 
of ABR type that is connections with a bit rate available 
time by time, and non-ABR connections, all treated as 



Brief description of the drawings 

The invention, together with further objects and 
advantages thereof, may be understood with reference 
to the following description, taken in conjuctionwith the 
accompanying drawings, and in wich: 

Fig. 1 shows the structure of the WFQ system 
according to this invention, in which the structure of 
the control block for the transmission queues of the 
device is shown according to a first embodiment; 
Fig. 2 shows a management flow chart of the serv- 
ices of the method of this invention, according to an 
embodiment like that illustrated in Fig. 1 ; 
Fig. 3 is a management flow chart of the services 
according to an alternative embodiment; 
Fig. 4 is a flow chart of insertion of the different 
types of transmission flows entering appropriate 
transmission queues organized in different fifos, 
according to said alternative embodiment of the 
WFQ system of the invention; 
Fig. 5 shows the flow chart of the scheduler, 
according to the alternative embodiment of the 
WFQ system of the invention; 
Fig. 6 is a functional chart of the WFQ system 
according to said alternative embodiment. 

Detailed description of a preferred embodiment of the 
invention. 

With reference to figure 1 , the traffic shaping device 
according to the invention is globally indicated with 
SORTER. The device has an ATM input link Bj and an 
output link B 0 . 

No relation exists between the bandwidth of the 
input link and the bandwidth of the output link. However, 
the bandwidth of the input link is typically much larger 
than the bandwidth of the output link (Bj » B 0 ), 

The incoming flow consists of cells belonging to a 
certain number of streams with different QoS levels. 
These streams consist in a number n of transmission 
flows of applications with available bandwidth or ABR 
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(for example the not real-time flows pertaining to a data 
file) for which the system guarantees the maximum 
bandwidth of availability and in a number n of transmis- 
sion flows of non-ABR applications (for example the 
real-time flows related to TV signals etc.), for which the 
system must however guarantee the established peak 
bandwidth (CBR or maximum priority concessions). 

The total bandwidth available on the link B Q is called 
R tot , the minimum agreed bandwidths of n transmission 
flows of ABR type are called RA if the fixed transmission 
bandwidths of m non-ABR transmission flows are called 
RNA j( . 

In this context the following relation Ej Raj + L\ 
RNAj <= R tot applies. 

The compliance with this relation is guaranteed, 
during the negotiation step, by a correct assignment to 
the single applications of the values Raj and RNAj. 

The ATM cells approaching the link Bj enter one of 
the n queues QA 1( QA 2 , ... QA n if belonging to an ABR 
transmission flow, while they enter a single QHA queue 
if belonging to a non-ABR transmission flow 

The SORTER device contains an SCB control block 
whose structure is shown in the "expansion" of Fig. 1 
defined by the dashed line parameter. 

This control block contains two logic FIFOs, indi- 
cated respectively with FGB (Fifo Bandwidth Granted) 
and FAB (Fifo Available Bandwidth) and an RT_EMPTY 
flag. 

The two FIFOs FGB and FAB contain pointers Qidj 
to the transmission queues of the SORTER device. 

The SCB control block also contains a 
TK_COUNTER storage device which contains, for each 
of the transmission queues, a respective TKNj number. 
These TKIj numbers represent the tokens at the dis- 
posal of each transmission queue. 

The number of tokens assigned to each transmis- 
sion queue belonging to an ABR transmission flow in a 
certain TR period, called renewal period, is proportional 
to the minimum bandwidth assigned during the negotia- 
tion step. 

The TR period is a whole multiple of the tc cell time 
of the SORTER device, i.e. of the time that the SORTER 
device needs to transmit a cell on the link B 0 . 

The optimal choice of the value of the TR period is, 
as will appear clearer later, fundamental for the correct 
operation of the SORTER device. 

The renewal period is .defined TR = (R tot /G)*tc 
where the factor G characterizes the minimum granular- 
ity related to the manageable minimum bandwidth. 

With reference to the enclosed Fig. 2, the method 
for the distribution of the available bandwidth according 
to the invention is illustrated. 

The method will be described for a single TR 
period. 

At the start of the TR period, the SCB block moves 
to an IN IT — TOKEN step , during which the 
TK_COUNTER storage device is initialized and the 
respective tokens assigned to each of the ABR trans- 



mission queues. 

The number of tokens assigned to each queue 
belonging to ABR transmission flows is equal to RA/G. 

The SCB block subsequently moves to an 
s INIT_FIFO step, during which any transmission queue 
pointers contained in the FIFOs FGB and FAB are 
removed and the identifications of the queues which 
have cells to transmit are inserted in the FIFO FGB. 

The SCB block updates the value contained in the 
w RT_EMPTY flag, writing the true logical value if the 
QNA queue containing the cells belonging to non-ABR 
flows is empty, the false logical value in contrary case. 

The SCB block decreases the current TR time,( 
DEC_TR step) by one unit and moves to an 
is IS_END_TR test step in which it checks if the TR time is 
not terminated. 

If the TR time is not yet terminated, the SCB block 
moves to an ID_RT_EMPTY test step in which it checks 
if the RT_EMPTY flag is at high logical level. 
20 If the IS_RT_EMPTY test indicates that there are 
cells belonging to non-ABR flows to be transmitted, the 
SCB block moves to a SERVINGJTT step. 

During this step, the SCB block serves the QNA 
queue containing the cells belonging to the non-ABR 

25 flOWS. 

If the RT_EMPTY flag indicates that there are no 
cells belonging to real-time flows to be transmitted, the 
SCB block moves to an IS_FGB_EMPTY step in which 
it checks if the FIFO FGB still contains pointers to trans- 
30 mission queues. 

If the FIFO FGB contains pointers to transmission 
queues, the SCB block moves to a SERVING_FGB 
step. 

During this step the SCB block serves the queue 
35 currently pointed by the FIFO FGB, decreases the cor- 
responding number of tokens stored in the 
TK_COUNTER device by one unit and removes its 
pointer from the FIFO FGB. 

If the queue just served is not empty, its pointer is 
40 considered for the reinsertion. If the queue just served 
has still tokens available, its pointer is reinserted in the 
FIFO FGB. If it has no more tokens available, its pointer 
is inserted in the FIFO FGB. 

At the end of the SERVING_FGB step, the SCB 
45 block returns to the DEC_TR step, in which it decreases 
the TR time by one unit and repeats the SERVING_FGB 
step. This step is carried out in cycles until the TR time 
is exhausted or until the FIFO FGB has been emptied. 
If the FIFO FGB is empty, the IS_FGB_EMPTY test 
so is positive and the SCB control block therefore goes on 
to treat the second FIFO FAB. 

if the second FIFO FAB contains pointers to trans- 
mission queues, the SCB block moves to a 
SERVING_FAB step. 
55 During this step the SCB block serves the queue 
currently pointed by the FIFO FAB and removes its 
pointer. 

If the queue just served is not empty, its pointer is 
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re-inserted in the FIFO FAB. 

At the end of the SERVING_FAB step, the SCB 
blocks returns to the DEC_TR step, in which it 
decreases the TR time by one unit and repeats the 
SERVING_FAB step until the available TR time is 5 
exhausted. 

At the end of the TR time the IS_END__TR test is 
positive, and the SCB block returns to the initialization 
steps INITJTOKEN and INIT_FIFO in which the tokens 
are newly distributed and the contents of the FIFOs re- 10 
initialized. 

The RT_EMPTY flag permits the cells stored in the 
QNA queue to be served immediately. 

The FIFO FGB assumes the role of high priority 
FIFO. The transmission queues present in it are queues 15 
which still have tokens available and which therefore are 
definitely entitled to see their cells transmitted on the 
input link. 

During the TR time interval the FIFO FGB is 
scanned in cycles and the queues indicated by it are 20 
uniformly served. 

Due to the decrease of the value of the tokens and 
the progressive transmission of their cells, these 
queues may find themselves in different states. 

A queue may simultaneously exhaust its tokens 25 
and no longer have cells to transmit. This queue will 
belong to a transmission flow which, during the TR 
period, has transmitted cells exactly at the speed deter- 
mined by the assigned minimum bandwidth. 

A queue may instead have no more cells to transmit 30 
before having exhausted its tokens. This queue will 
belong to a transmission flow which, during the TR 
period, has transmitted cells at a lower speed than that 
determined by the assigned minimum bandwidth. 

Finally, a queue may exhaust its tokens before hav- 35 
ing been able to transmit all its cells. This queue will 
belong to a transmission flow which, during the TR 
period, has transmitted cells at a higher speed than that 
determined by the assigned minimum bandwidth. 

During the TR period, due to the constant emptying 40 
of the FIFO FGB, only two cases may take place. 

In the first case, the total emptying of the FIFO FGB 
coincides with the end of the TR period. This means 
that, during the TR period, all the transmission queues 
have transmitted at least at the speed determined by the 45 
assigned minimum bandwidth. In this case, during this 
period, there will not be any excess bandwidth available 
to distribute and the FIFO FAB will not even be treated. 

In the second case, the total emptying of the FIFO 
FGB takes place before the end of the TR period. This so 
means that, during the TR period, at least one of the 
transmission queues has transmitted at a lower speed 
than that determined by the assigned minimum band- 
width. In this case, during this period, there will be 
excess bandwidth available to distribute. The FIFO FAB 55 
is scanned in cycles in such a way that all the queues 
present in it are uniformly served, regardless of the 
number of tokens originally owned by it and the number 
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of cells still to be transmitted. 

It may be appreciated that, in this way, even in the 
worst case of queues which all transmit at a higher 
speed than that determined by the assigned minimum 
bandwidth, all the queues are correctly served with at 
least the agreed minimum bandwidth. 

Thanks to the presence of the RT_EMPTY flag and 
the IS_RT_EMPTY test step, the queues belonging to 
non-ABR transmission flows are definitely served. The 
cells belonging to these queues have precedence. even 
over those belonging to the queues indicated in the high 
priority FIFO FGB. 

Also appreciable is the fact that, thanks to the scan- 
ning methods of the FIFO FAB, no transmission queue 
manages to monopolize the output link, even if it has a 
large number of cells to transmit. 

In fact the FIFO FAB contains queue indicators 
which have completely exhausted their tokens, regard- 
less of the number of tokens initially owned by them. 
These queues therefore have an equal right to be 
served. 

The extreme simplicity of the method according to 
this invention, which permits a simple and inexpensive 
implementation, may be observed. 

The device is also easily configurable and adapta- 
ble to different situations. 

The negotiated bandwidths are easily varied by 
simply changing the number of tokens at the disposal of 
each application. 

During the negotiation step, it is also possible to 
assign the tokens in such a way that the sum of all the 
minimum bandwidths of all the ABR flows and of all the 
peak bandwidths of the non-ABR flows are always 
below the total bandwidth of the output link. 

This would make it possible to always have availa- 
ble a certain excess bandwidth for possible distribution. 

The variation of the TR period, or of the granularity 
with which the tokens are distributed, makes it possible 
to improve the performances of the device in each situ- 
ation. 

While the method and the WFQ system described 
above permits the management of connections of 
VBRnrt and ABR type exploiting a token mechanism for 
the guaranteed bandwidth services (MCR for ABR con- 
nections), with insertion of the relevant queues in the 
high priority FIFO and distributing the available band- 
width among the ABR connections through the insertion 
of the relevant queues in the low priority FIFO, through 
a more developed implementation of the method and 
relevant WFQ system described above, it is made suit- 
able to manage, besides the above mentioned traffic 
classes, including the so-called CBR classes, also the 
traffic classes UBR and VBR. 

This preferred implementation of the method of the 
invention is based on the fact that: 

the CBR connections are all identified in a same 
queues by block of appurtenance, while, if class 
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UBR connections are required, a specific queue is 
guaranteed for each connection in a third buffer of 
fifo FUB type, defined of very low priority, as illus- 
trated in Fig. 6; 

the VBR connections are treated like the ABR con- 
nections making a number of tokens equal to the 
SCR value. These connections do not therefore 
contribute in the use of the available bandwidth; 
the single QNA queue of non-ABR connections, 
typically CBR connections with constant bit rate, is 
served with priority by the system through the use 
of a flag (flag register RT), as already described 
above in relation to the basic layout of Fig. 1 , while 
the UBR queues, if they have cells to transmit, are 
inserted in a third FIFO named FUB, besides the 
two already provided by the basic system (FGB and 
FAB), which is defined of very low priority (VLPF 
Very Low Priority Fifo). 

This third FIFO is scanned for a possible service 
only if the flat relating to the CBR connections is extin- 
guished and the other two FIFOs, FGB and FAB (High 
Priority Fifo and Low Priority Fifo) do not have identifica- 
tions of queues to be served. 

Also in this case, as for the ABR queues, the avail- 
able bandwidth is uniformly distributed among the 
UBRs. 

At level of general organization of the service by the 
WFQ machine of the invention, this expansion of the 
management capacity of the system is exemplified in 
the service flow diagram in Fig. 3. 

With respect to the flow in Fig. 2, a further test suit- 
able to establish if also the low priority FIFO FAB is 
empty is substantially added. If also the FAB is empty, 
the system takes into consideration the queues at 
present accumulated in a third very low priority FIFO 
(named FUB) in which the transmission queues of UBR 
class are possibly loaded. 

The transmission queues with guaranteed band- 
width are therefore inserted in the high priority FIFO 
(FGB) and the transmission queues definable with avail- 
able bandwidth are inserted in the low priority FIFO 
(FAB), while the transmission queues with unspecified 
bandwidth are inserted in the very low priority FIFO 
(FUB). 

A further function of this solution makes it possible 
to control the peak of single non-CBR connections. 

Unlike the known systems in which the peak control 
is implemented through a virtual spacing mechanism 
which "slows down" the bit rate inserting some waiting 
cycles in the calendar system, in practice waiting for the 
first event to be served, if infringing the peak value, until 
it is possible to transmit it without infringing the peak bit 
rate of the particular connection, the system of this 
invention makes it possible instead to apply a selective 
peak control mechanism on the single queues, thus 
being able to continue to serve the transmission queues 
which do not need peak control according to a pure 



WFQ technique. 

All the queues therefore contribute to the use of the 
available bandwidth, maintaining the mechanisms of 
statistical sharing of the bandwidth, but only the queues 
5 which need peak control are limited by this threshold 
value. 

The need to insert a checking mechanism on the bit 
rate time basis to fulfil the requisites of transmission 
queues with peak control is solved by this invention 

w using, upstream from the WFQ system, a scheduler 
block, which has the function of supplying the WFQ 
machine with information on the possibility or impossi- 
bility of inserting queue identifications in one of the 
FIFOs without infringing the peak value. 

15 According to a particularly preferred embodiment of 
this block, a calendar mechanism is used, although 
other equivalent scheduler mechanisms are equally 
applicable. 

In Fig. 4 the flow chart is shown which, according to 
20 the method of the invention, governs the insertion of 
each input queue in the relevant FIFOs, distinguishing if 
a peak control should or should not be applied to the 
particular input queue. 

Since the CBR connections in input are all identified 
25 in a same QNA transmission queue by block of appurte- 
, nance and conventionally served with priority, through 
the use of a flag, all the other connections are previ- 
ously tested by the system according to the flow chart in 
Fig. 4 and identified in an equal number of queues 
30 which are inserted in one of the three FIFOs of the sys- 
tem FGB, FAB and FUB. 

The scheduler block of the system of the invention, 
according to this preferred embodiment, either imple- 
mented by a calendar mechanism or by other equivalent 
35 mechanism, performs its function of peak shaper 
through a peak control table using two bits for each 
queue managed by the WFQ system. 

One of the two bits represents a wait bit generated 
by the algorithm of Fig. 4. 
40 The second bit of the pair is a flag which is, set by 
the scheduler/shaper block 

The update from scheduler is combined with the 
wait bit to establish the qualification for the transmission 
in compliance with the maximum peak speed of the par- 
45 ticular queue. 

The algorithm is illustrated in the flow chart in Fig. 

5. 

A functional layout of the system of the invention 
according to this preferred embodiment is shown in Fig. 

so 6. For comparison with the basic layout in Fig, 1, the 
presence is observed in the SCB control block of the 
third FIFO FUB, of the table with two bits of peak control 
and of the scheduler block which may be implemented 
by a common calendar mechanism or another equiva- 

55 lent mechanism. 

The queues without peak control continue to be 
managed by the WFQ machine (SORTER) in a method 
of operation according to a pure WFQ algorithm. 
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In fact, the algorithm of the service is independent 
from the fact that the Qid transmission queues extracted 
are with or without rate shaping. This makes it possible 
to use all the service slots of the block if cells must be 
transmitted between the queues without rate shaping 5 
and/or between the queues with rate shaping. 

In this form the system makes it possible to main- 
tain the renewal period of the WFQ of sufficient length to 
permit the management of any guaranteed minimum 
bandwidth, while the SCHEDULER block supplies, w 
through a flag (traffic light), the scheduling necessary to 
control the peak very closely to the ideal profile (apart 
from the CDV inserted by the calendar mechanisms). 

The system also makes possible to manage the 
excess bandwidth in integrated manner, uniformly dis- is 
tributing it among the various connections and inter- 
venes on the connections which need rate shaping only 
when their service would cause an infringement of the 
peak bandwidth. 

Therefore, while a particular embodiment of the 20 
present invention has been shown and described, it 
should be understood that the present invention is not 
limited thereto since other embodiments may be made 
by those skilled in the art without departing from the 
scope thereof. It is thus contemplated that the present 25 
invention encompasses any and all such embodiments 
covered by the following claims. 

Claims 

30 

1. Method for the management of resources in ATM 
technique for Weighted Fair Queuing (WFQ) appli- 
cations in a system (SORTER) for the transmission 
on an output link (B c ) of flows of ATM ceils pertain- 
ing to an input link (Bj) of the type including service 35 
classes with different quality (QoS), an assigned 
guaranteed minimum bandwidth (Raj) being associ- 
ated to each of said flows at the set up step of the 
service, and each of said flows of cells exploiting 
the possibility to have further bandwidth assigned 40 
on said output link (B Q ), characterized bv the fact of 
assigning to each of said flows, in a renewal time 
(TR) whole multiple of the. transmission time of a 
cell (tc) on said output link (B 0 ), a respective 
number of access rights to said output link (B Q ) or 45 
token (TKNj) proportional to said minimum band- 
width (Raj), and, for each renewal time (TR), includ- 
ing the steps of: 

inserting the cells of each of said flows in a so 
respective transmission queue (QAj); 
assigning (INIT_TOKEN) to each of said trans- 
mission queues (Qaj) its own token number 
(TKNj); 

inserting (INIT_FGB) indicators (Qidj) of said 55 
transmission queues (Qaj) inside a high priority 
storage structure (FGB); 
scanning (SERVING_FGB) said high priority 



storage structure (FGB) in order to serve the 
transmission queues in FIFO order, decreasing 
the tokens at their disposal and transferring the 
indicators of the queues which have exhausted 
their tokens inside a low priority storage struc- 
ture (FAB); 

- after terminating (IS_FGB__EMPTY) the scan 
of said high priority storage structure (FGB), 
scanning (SERVING_FAB) said low priority 
storage structure (FAB) in order to serve the 
queues indicated by it until the end of the 
renewal time (TR) occours. 

2. Method according to claim 1, characterized bv the 
fact that said step of scanning said high priority 
storage structure (FGB) includes, for each cell time 
(tc), the following steps: 

serving the transmission queue (Qaj) indicated 
by said high priority storage structure (FGB); 
decreasing by one unit the number of tokens 
(TKNj) at the disposal of said transmission 
queue (Qaj); 

removing the indicator of said queue from said 
high priority storage structure (FGB); 
re-inserting, if in said just served transmission 
queue (Qaj) further cells to be transmitted are 
present, the indicator of this transmission 
queue (Qaj) inside said high priority storage 
structure (FGB) if a number of tokens (TKNj) 
over zero remains available to this transmission 
queue, and, in the negative, inside said low pri- 
ority structure (FAB). 

3. Method according to claim 1, characterized by the 
fact that said step of scanning said low priority stor- 
age structure (FAB) includes, for each cell time, the 
following steps: 

serving the transmission queue (QAj) indicated 
by said low priority storage structure (FAB); 
removing the indicator of said queue of said 
low priority storage structure (FAB); 
re-inserting, if further cells to be transmitted 
are present in said just served transmission 
queue (QAj), the indicator of said transmission 
queue (Qaj) inside said low priority storage 
structure (FAB). 

4. Method according to claim 1, characterized by the 
fact that said input link (Bj) also includes flows of 
ATM cells which transmit at peak and which do not 
exploite therefore said further bandwidth possibly 
available on said output link (B 0 ), and, for each 
renewal time (TR), including the following further 
steps: 

inserting said cells of each of said flows which 
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transmit at peak in a common queue (QNA); 
transmitting the cells present in said common 
queue (QNA) on said output link (B 0 ) until said 
common queue (QNA) is empty 
(IS_RT_EMPTY); 5 
only after having transmitted all the cells 
present in said common queue (QNA), resum- 
ing said scanning step (SERVING_FGB) of 
said high priority storage structure (FGB) or 
eventually said scanning step (SERVING_FAB) w 
of said low priority storage structure (FAB). 

5. Method according to claim 4, characterized by the 
fact that said input link (B f ) also includes flows of 
ATM cells pertaining to connections with unspeci- is 
tied bit rate (UBR) whose transfer is not guaranteed 

in a certain time and, for each renewal period (TR), 
the method includes the following further steps of: 

inserting said cells of said flows with non-guar- 20 
anteed transfer time in a third buffer of very low 
priority FIFO type (FUB) in an equal number of 
transmission queues; 

scanning said third very low priority FIFO 
(FUB) whenever said common queue (QNA) of 25 
said high priority buffer (FGB) is empty, and ali 
the transmission queues inserted in said high 
priority FIFO buffer (FGB) and the transmission 
queues inserted in said low priority FIFO buffer 
(FAB) ar empty. 30 

6. Device according to claim 1, characterized by the 
fact that said input link (Bj) also includes flows of 
ATM cells of connections requiring a peak band- 
width control so as not to exceed a predetermined 35 
maximum bandwidth value in the transmission of 
said flows through said output link (B 0 ), and by the 
fact that, for each renewal period (TR) the method 
includes the scheduling of the transmission through 
said output link (B 0 ) of cells belonging to flows with 40 
limited peak bandwidth, inserting the cells coming 
from said input link (Bj) in a respective queue of one 

of said FIFO buffers (FGB, FAB or FUB), depending 
on the class of the relevant flow; 

the insertion of each cell belonging to said 45 
flows with limited peak bandwidth being condi- 
tioned by a peak control table with two bits updated 
by a scheduler. 

7. Method according to claim 6, characterized by the so 
fact that one of said two bits of said peak control 
table is generated as wait bit from the WFQ system 
and the other bit of said pair is a flag set by said 
scheduler. 

55 

8. Method according to claim 1, characterized by the 
fact that said high and low priority storage struc- 
tures operate according to FIFO approach. 



9. Management system of resources in ATM tech- 
nique for Weighted Fair Queuing (WFQ) applica- 
tions, including an input link (Bj) on which transit 
flows of ATM cells belonging to service classes with 
different quality (QoS), to each of said flows being 
associated a respective guaranteed minimum 
bandwidth (Raj) at the set up step of the service, 
and an output link (B 0 ), and each of said flows 
exploiting the possibility to have further bandwidth 
assigned on said output link (B G ), characterized by 
the fact of including; 

a number of transmission queues (QA 1( QA 2 , 
QA n ) equal to the number of said flows of ceils, 
each of said queues containing the ATM cells 
of a respective flow of cells, and assigning to 
each transmission queue, in a renewal period 
(TR) a whole multiple of the transmission time 
of a cell (tc) on said output link (B 0 ), a respec- 
tive nember of access rights to said output link 
(B Q ) or token (TNKj) proportional to said mini- 
mum bandwidth (Raj; 

a control block (SCB) including a storage 
device (TK_COUNTER) which contains, for 
each of said transmission queues, a respective 
number of access rights to said output link (B 0 ) 
or token (TKNj) proportional to said minimum 
bandwidth (Raj); 

a high priority storage structure (FGB) which 
contains indicators (Qidj) of the transmission 
queues (Qaj) which have at their disposal a 
number of tokens (TKNJ over zero; 

a low priority storage structure (FAB) 
which contains indicators (Qidj) of the transmis- 
sion queues (Qaj) which have at their disposal 
a number of tokens (TKNj) equal to zero, 
said high priority storage structure (FGB) being 
connected with said low priority storage struc- 
ture (FAB) in such a way that: 

one of said indicators (Qidj) present in said 
high priority storage structure may be 
transferred to said low priority storage 
structure as the exhaustion of the tokens at 
its disposal stored in said storage device 
(TK_CO U NTE R) occours; 
a transmission queue indicated in said low 
priority storage structure (FAB) can only be 
served when said high priority storage 
structure (FGB) does not contain transmis- 
sion queue indicators. 

10. System according to claim 9, characterized by the 
fact that said input link (Bj) also includes flows of 
ATM cells which transmit at peak and which do not 
have therefore the possibility of exploiting said fur- 
ther bandwidth possibly available on said output 
link (Bj), and further caracterized by the fact of 
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including a further transmission queue (QNA) 
which contains the cells of all those flows of ATM 
cells which transmit at peak and an indicator device 
(RT_EMPTY) which contains an indication on the 
filling state of said further transmission queue, said 5 
indicator device being connected with said high pri- 
ority storage structure (FGB) and said low priority 
storage structure (FAB) in such a way that a trans- 
mission queue indicated in said high priority stor- 
age structure (FGB) or in said low priority storage w 
structure (FAB) can only be served when said indi- 
cator device (RT_EMPTY) indicates the absence of 
cells to be transmitted inside said further transmis: 
sion queue (QNA). 

75 

1 1 . System according to claim 1 0, characterized by the 
fact that from said input link (Bj) also includes flows 
of ATM cells relating to connections with unspeci- 
fied rate (UBR) whose transfer is not guaranteed in 
a certain time and said system also including: 20 

a third very low priority storage structure (FUB) 
containing the indicators (Qidm, Qidk,...) of 
transmission codes relating to said connec- 
tions with unspecified rate (UBR); 25 
scanning means of said third very low priority 
storage structure (FUB) whenever said com- 
mon queue (QNA) is empty, and all the trans- 
mission queues whose indicators are inserted 
in said first high priority storage structure 30 
(FGB) and the transmission codes whose indi- 
cators are inserted in said second low priority 
storage structure (FAB) are empty. 



12. System according to claim 10, characterized by the 35 
fact that said input link (Bj) includes flows of ATM 
cells of connections requiring a peak rate control in 
order not to exceed a certain maximum rate value 
in the transmission of said flows through said output 
link (B 0 ), and said system also includes means 40 
adapted to schedule the transmission through said 
output link (B c ) of cells belonging to flows with lim- 
ited peak rate, inserting the relevant cells coming 
from said input link (Bj) in a respective queue of one 
of said storage structures (FGB, FAB, FUB), 45 
depending on the class of the relevant flow; 

said means using a peak rate control table 
with two bits, one of said two bits being generated 
as wait bit from said control block (SCB) and the 
other of said two bits being a flag updated by a so 
• scheduler. 



13. System according to any of the previous claims, 
characterized by the fact that said storage struc- 
tures are FIFO type memories. 55 
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(54) Method and device for the management of resources in ATM technique for weighted fair 
queuing (WFQ) applications 

(57) The system (SORTER) includes an input link 
(Bj) on which transit flows of ATM cells belonging to 
service classes with different quality (QoS), and an out- 
put link (B 0 ), and including: 

a plurality of transmission queues (OA-,, QA 2 , 
QA n ); 

a control block (SCB) which contains a respective 
number of access rights to said output link (B 0 ) or 
tokens (TKNj); 

a high priority storage structure (FGB); 
a low priority storage structure (FAB); 
at least one further transmission queue (QNA) 
which contains cells relating to all the flows which 
they transmit at a constant or peak rate, the indica- 
tors of which are contained in said high priority stor- 
age structure. 

The system optionally includes a third storage structure 
with very low priority (FUB) for flows with unspecified 
rate, and a scheduler for the management of flows at 
limited peak rate. 
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